<!--
  - Copyright 2014-2018 the original author or authors.
  -
  - Licensed under the Apache License, Version 2.0 (the "License");
  - you may not use this file except in compliance with the License.
  - You may obtain a copy of the License at
  -
  -     http://www.apache.org/licenses/LICENSE-2.0
  -
  - Unless required by applicable law or agreed to in writing, software
  - distributed under the License is distributed on an "AS IS" BASIS,
  - WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
  - See the License for the specific language governing permissions and
  - limitations under the License.
  -->

<template>
  <div v-html="formatted" class="formatted" />
</template>

<script>
  import {Autolink} from '@/utils/autolink';
  import objToString from '@/utils/objToString';

  const autolink = new Autolink({truncate: {
      length: 50,
      location: 'smart'
    }});

  export default {
    props: {
      value: {
        // eslint-disable-next-line vue/require-prop-type-constructor
        type: null,
        required: true
      },
    },
    computed: {
      formatted() {
         return autolink(objToString(this.value));
      }
    }
  }
</script>

<style lang="scss">
  .formatted {
    white-space: pre;
  }
</style>
